/*
 * Copyright (C) 2015 yixun All Rights Reserved.
 * 
 * CustomerInfoService.java
 */
package com.yixun.qfbao.service;

import com.yixun.common.page.Page;
import com.yixun.qfbao.model.CommissionRules;
import com.yixun.qfbao.model.CustomerInfo;
import com.yixun.qfbao.model.dto.CustomerInfoDto;

import java.math.BigDecimal;
import java.util.List;

/**
 * [文件名称]<br>
 * CustomerInfoService.java<br>
 * <br>
 * [文件描述]<br>
 * 客户信息 service interface<br>
 * <br>
 * [修改记录]<br>
 * 2015-10-14 15:34:13 创建 陶俊代码生成器<br>
 * 
 * @author 陶俊代码生成器
 * @version 1.00
 */
public interface CustomerInfoService {

	/**
	 * @param entity 搜索条件
	 * @param begin 分页开始行数[不包含]
	 * @param end 分页结束行数[包含]
	 * @return 分页记录
	 */
	Page<CustomerInfo> getPageModel(CustomerInfoDto entity, int begin, int end);

	/**
	 * 查询列表
	 * @param entity 搜索条件
	 * @return 分页记录
	 */
	List<CustomerInfo> selectListByDto(CustomerInfoDto entity);

	/**
	 * 查询单个
	 * @param entity 搜索条件
	 * @return 分页记录
	 */
	CustomerInfo selectByDto(CustomerInfoDto entity);

	/**
	 * @param id 根据主键搜索
	 * @return 一行记录
	 */
	CustomerInfo selectById(Long id);

	/**
	 * @param entity 根据pojo搜索如果主键为空则返回它本身
	 * @return 一行记录或本身
	 */
	CustomerInfo selectBy(CustomerInfo entity);

	/**
	 * @param entity 新增记录的详细信息
	 * @return 新增行数
	 */
	CustomerInfoDto create(CustomerInfoDto entity);
	/**
	 * @param entity 更新记录的详细信息
	 * @return 更新行数
	 */
	int update(CustomerInfoDto entity);
	/**
	 * @param entity 待删除的记录信息
	 * @return 删除行数
	 */
	int destroy(CustomerInfoDto entity);
	/**
	 * @param entity 新增或更新
	 * @return 新增行数
	 */
	int saveOrUpdate(CustomerInfoDto entity);

	/**
	 * 获取生效的规则
	 * @param companyId 机构ID
	 * @param premisesId 楼盘ID
	 * @return
	 */
	List<CommissionRules> getNewRules(Long companyId, Long premisesId);
	
	/**
	 * 按照新的方式获取佣金金额或佣金比例
	 * @param companyId 机构ID
	 * @param premisesId 楼盘ID
	 * @param dealAmount 成交金额
	 * @param flag 是否计算当次成交额
	 * @return CommissionRules 佣金规则
	 * @author shaoping.jiao
	 */
	CommissionRules getNewCommission(Long companyId, Long premisesId, BigDecimal dealAmount, boolean flag, String addOrDel);
}
